home *** CD-ROM | disk | FTP | other *** search
/ System Booster / System Booster.iso / Archives / ForCLI / Expand.lha / Expand / Unexpand.c < prev    next >
Encoding:
C/C++ Source or Header  |  1992-05-14  |  3.4 KB  |  133 lines

  1. /*-
  2.  * Copyright (c) 1980 The Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  * 1. Redistributions of source code must retain the above copyright
  9.  *    notice, this list of conditions and the following disclaimer.
  10.  * 2. Redistributions in binary form must reproduce the above copyright
  11.  *    notice, this list of conditions and the following disclaimer in the
  12.  *    documentation and/or other materials provided with the distribution.
  13.  * 3. All advertising materials mentioning features or use of this software
  14.  *    must display the following acknowledgement:
  15.  *    This product includes software developed by the University of
  16.  *    California, Berkeley and its contributors.
  17.  * 4. Neither the name of the University nor the names of its contributors
  18.  *    may be used to endorse or promote products derived from this software
  19.  *    without specific prior written permission.
  20.  *
  21.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  22.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  23.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  24.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  25.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  26.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  27.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  28.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  29.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  30.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  31.  * SUCH DAMAGE.
  32.  */
  33.  
  34. #ifndef lint
  35. char copyright[] =
  36. "@(#) Copyright (c) 1980 The Regents of the University of California.\n\
  37.  All rights reserved.\n";
  38. #endif /* not lint */
  39.  
  40. #ifndef lint
  41. static char sccsid[] = "@(#)unexpand.c    5.3 (Berkeley) 4/18/91";
  42. #endif /* not lint */
  43.  
  44. /*
  45.  * unexpand - put tabs into a file replacing blanks
  46.  */
  47. #include <stdio.h>
  48.  
  49. static char VersionId[] = "\0$VER: Amiga Unexpand (Joseph Hillenburg) 1.00BSD";
  50.  
  51. tabify(char c);
  52.  
  53. char genbuf[BUFSIZ];
  54. char linebuf[BUFSIZ];
  55. int all;
  56.  
  57. main(int argc,char **argv)
  58. {
  59.     register char *cp;
  60.  
  61.     argc--, argv++;
  62.     if(argc > 0 && argv[0][0] == '-') {
  63.         if(strcmp(argv[0], "-a") != 0) {
  64.             fprintf(stderr, "unexpand [ -a ] [ file ... ]\n");
  65.             exit(1);
  66.         }
  67.         all++;
  68.         argc--, argv++;
  69.     }
  70.     do {
  71.         if(argc > 0) {
  72.             if(freopen(argv[0], "r", stdin) == NULL) {
  73.                 perror(argv[0]);
  74.                 exit(1);
  75.             }
  76.             argc--, argv++;
  77.         }
  78.         while(fgets(genbuf, BUFSIZ, stdin) != NULL) {
  79.             for(cp = linebuf; *cp; cp++)
  80.                 continue;
  81.             if(cp > linebuf)
  82.                 cp[-1] = 0;
  83.             tabify(all);
  84.             printf("%s", linebuf);
  85.         }
  86.     } while(argc > 0);
  87.     exit(0);
  88. }
  89.  
  90. tabify(char c)
  91. {
  92.     register char *cp, *dp;
  93.     register int dcol;
  94.     int ocol;
  95.  
  96.     ocol = 0;
  97.     dcol = 0;
  98.     cp = genbuf, dp = linebuf;
  99.     for(;;) {
  100.         switch(*cp) {
  101.  
  102.         case ' ':
  103.             dcol++;
  104.             break;
  105.  
  106.         case '\t':
  107.             dcol += 8;
  108.             dcol &= ~07;
  109.             break;
  110.  
  111.         default:
  112.             while(((ocol + 8) &~ 07) <= dcol) {
  113.                 if(ocol + 1 == dcol)
  114.                     break;
  115.                 *dp++ = '\t';
  116.                 ocol += 8;
  117.                 ocol &= ~07;
  118.             }
  119.             while(ocol < dcol) {
  120.                 *dp++ = ' ';
  121.                 ocol++;
  122.             }
  123.             if(*cp == 0 || c == 0) {
  124.                 strcpy(dp, cp);
  125.                 return;
  126.             }
  127.             *dp++ = *cp;
  128.             ocol++, dcol++;
  129.         }
  130.         cp++;
  131.     }
  132. }
  133.